home *** CD-ROM | disk | FTP | other *** search
/ Visual Basic Source Code / Visual Basic Source Code.iso / vbsource / optivc32 / vimath.h < prev    next >
C/C++ Source or Header  |  1999-03-06  |  3KB  |  89 lines

  1. /*  VImath.h
  2.  
  3.   vector management functions for data type "int":
  4.   integer arithmetics and mathematics.
  5.  
  6.   Copyright (c) 1996-1999 by Martin Sander
  7.   All Rights Reserved.
  8. */
  9.  
  10. #ifndef __VIMATH_H
  11. #define __VIMATH_H
  12.  
  13. #if !defined( __VECLIB_H )
  14.    #include <VecLib.h>
  15. #endif
  16.  
  17. #ifdef __cplusplus
  18.    extern "C" {
  19. #endif
  20.  
  21. /******************   Basic  Arithmetics   *************************/
  22.  
  23. void  __vf  VI_neg( iVector Y, iVector X, ui size );
  24. void  __vf  VI_abs( iVector Y, iVector X, ui size );
  25.  
  26. void  __vf  VIo_addC(  iVector Y, iVector X, ui size, int C );
  27. void  __vf  VIo_subC(  iVector Y, iVector X, ui size, int C );
  28. void  __vf  VIo_subrC( iVector Y, iVector X, ui size, int C );
  29. void  __vf  VIo_mulC(  iVector Y, iVector X, ui size, int C );
  30. #ifdef V_trapIntError
  31.     #define VI_addC     VIo_addC
  32.     #define VI_subC     VIo_subC
  33.     #define VI_subrC    VIo_subrC
  34.     #define VI_mulC     VIo_mulC
  35. #else
  36.     void  __vf  VI_addC(  iVector Y, iVector X, ui size, int C );
  37.     void  __vf  VI_subC(  iVector Y, iVector X, ui size, int C );
  38.     void  __vf  VI_subrC( iVector Y, iVector X, ui size, int C );
  39.     void  __vf  VI_mulC(  iVector Y, iVector X, ui size, int C );
  40. #endif
  41. void  __vf  VI_divC(  iVector Y, iVector X, ui size, int C );
  42. void  __vf  VI_divrC( iVector Y, iVector X, ui size, int C );
  43. void  __vf  VI_modC(  iVector Y, iVector X, ui size, int C );
  44. void  __vf  VI_maxC(  iVector Y, iVector X, ui size, int C );
  45. void  __vf  VI_minC(  iVector Y, iVector X, ui size, int C );
  46.  
  47. void  __vf  VIo_addV(  iVector Z, iVector X, iVector Y, ui size );
  48. void  __vf  VIo_subV(  iVector Z, iVector X, iVector Y, ui size );
  49. void  __vf  VIo_subrV( iVector Z, iVector X, iVector Y, ui size );
  50. void  __vf  VIo_mulV(  iVector Z, iVector X, iVector Y, ui size );
  51. #ifdef V_trapIntError
  52.     #define VI_addV    VIo_addV
  53.     #define VI_subV    VIo_subV
  54.     #define VI_subrV   VIo_subrV
  55.     #define VI_mulV    VIo_mulV
  56. #else
  57.     void  __vf  VI_addV(  iVector Z, iVector X, iVector Y, ui size );
  58.     void  __vf  VI_subV(  iVector Z, iVector X, iVector Y, ui size );
  59.     void  __vf  VI_subrV( iVector Z, iVector X, iVector Y, ui size );
  60.     void  __vf  VI_mulV(  iVector Z, iVector X, iVector Y, ui size );
  61. #endif
  62. void  __vf  VI_divV(  iVector Z, iVector X, iVector Y, ui size );
  63. void  __vf  VI_divrV( iVector Z, iVector X, iVector Y, ui size );
  64. void  __vf  VI_modV(  iVector Z, iVector X, iVector Y, ui size );
  65. void  __vf  VI_maxV(  iVector Z, iVector X, iVector Y, ui size );
  66. void  __vf  VI_minV(  iVector Z, iVector X, iVector Y, ui size );
  67.  
  68. /******************** Accumulation (Y += X) ******************************/
  69.  
  70. void __vf VI_accV(   iVector Y, iVector   X, ui size );
  71. void __vf VI_accVBI( iVector Y, biVector  X, ui size );
  72. void __vf VI_accVSI( iVector Y, siVector  X, ui size );
  73.  
  74. /*****************   Bit-wise operations  *********************/
  75.  
  76. void    __vf  VI_shl( iVector Y, iVector X, ui size, unsigned C );
  77. void    __vf  VI_shr( iVector Y, iVector X, ui size, unsigned C );
  78.  
  79. void    __vf  VI_and( iVector Y, iVector X, ui size, int C );
  80. void    __vf  VI_or(  iVector Y, iVector X, ui size, int C );
  81. void    __vf  VI_xor( iVector Y, iVector X, ui size, int C );
  82. void    __vf  VI_not( iVector Y, iVector X, ui size );
  83.  
  84. #ifdef __cplusplus
  85. }
  86. #endif
  87.  
  88. #endif   /*  __VIMATH_H    */
  89.